
    *{
        padding:0px;
        margin:0px;
        box-sizing: border-box;
    }
    body,html{
        width: 100%;
    }
    body{
        overflow-x: hidden;
    }
    body.noScroll{
        overflow: hidden;
    }
    ul{
        list-style: none;
    }
    a{
        text-decoration: none;
        color: inherit;
    }
    .cursor{
        cursor: pointer;
    }
    a,
    .cursor{
        -webkit-tap-highlight-color:transparent;
    }
    .iv{
        display: inline-block;
        vertical-align: top;
    }
    input, select, textarea {
        display: block;
        margin: 0;
        padding: 0;
        width: 100%;
        outline: 0;
        border: 0;
        border-radius: 0;
        background: none transparent;
        color: inherit;
        font: inherit;
        line-height: normal;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
    }
    .flex{
        display:box;
        display: -webkit-box; 
        display: -moz-box;
        display: -webkit-flex; 
        display: -moz-flex; 
        display: -ms-flexbox;
        display: flex;
    }
    .flex-align-items{
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        -moz-box-pack:center;
        -webkit-align-items: center;
        align-items: center;
    }
    .flex-justify-content{
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        box-align:center;
    }
    .hvc{
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%);
    }
    .vc{
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
    }
    .hc{
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
    }
    .obj-c{
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .delay-1{
        transition-delay: .1s;
    }
    .delay-2{
        transition-delay: .2s;
    }
    .delay-3{
        transition-delay: .3s;
    }
    html.noScroll body{
        position: fixed;
    }
    .container.fillAll{
        min-height: 100vh;
        flex-direction: column;
        display:box;
        display: -webkit-box; 
        display: -moz-box;
        display: -webkit-flex; 
        display: -moz-flex; 
        display: -ms-flexbox;
        display: flex;
    }
    .fillAll main{
        flex:1;
    }
    .fill,
    .fillAft::after,
    .fillBf::before{
        content: '';
        position: absolute;
        top: 0px;
        left: 0px;
        width: 100%;
        height: 100%;
    }
    .hbc{
        position: relative;
    }
    .dc img:last-child,
    .hbc img:last-child{
        position: absolute;
        top: 0px;
        left: 0px;
    }
    .hbc img{
            transition: opacity .4s;
    }
    .hbc img:last-child,
    .hbc:hover img,
    .dc img:last-child{
        opacity: 0;
    }
    .hbc:hover img:last-child{
        opacity: 1;
    }
    #loadingDiv{
        position: fixed;
        width: 100%;
        height: 100%;
        z-index: 200;
        background: #fff;
        top: 0px;
        left: 0px;
    }

    *::-moz-selection{
        background:rgba(0,0,0,.78);
        color: #fff;
    }
    *::selection{
        background:rgba(0,0,0,.78);
        color: #fff;
    }


    .scroll{
        position: fixed;
        top: 0px;
        right: 0px;
        width: 5px;
        height: 100vh;
        z-index: 1000;
    }
    .mobileDevice .scroll{
        display: none;
    }
    .scroll *{
        position: absolute;
    }
    .scroll .bar{
        width: 100%;
        left: 0px;
        height: 164px;
        border-radius: 5px;
        background: rgb(104, 105, 120);
        top: 0px;
        z-index: 2;
    }

    header .menu ul li .ttl,
    .loc ul li{
        -webkit-tap-highlight-color:transparent;
    }
    header .menuBtn,
    header .logo{
        position: absolute;
        height: 150px;
        top: 50%;
        transform: translateY(-50%);
    }
    header>*{
        width: 150px;
    }
    header .logo{
        left: 0px;
        z-index: 90;
    }
    header .logo>*{
        width: 100%;
        height: 100%;
    }
    header .logo .pic{
        text-align: center;
        background: #1d1e2c;
        line-height: 150px;
    }
    header .logo .pic img{
        display: inline-block;
        vertical-align: middle;
        width: 100px;
    }
    header .logo .txt{
        position: relative;
        z-index: 2;
        border: 3px solid #fff;
        display: none;
    }
    header .logo.c .txt{
        display: none;
    }
    header .logo .txt::before,
    header .logo .txt::after{
        content: '';
        position: absolute;
        background: #fff;
        width: 16px;
        height: 2px;
        left: calc(50% - 8px);
    }
    header .logo .txt::before{
        top: -13px;
    }
    header .logo .txt::after{
        bottom: -13px;
    }
    header .logo .txt span{
        font-size: 14px;
        line-height: 18px;
        color: #1d1e2c;
        position: absolute;
        left: 20px;
        bottom: 30px;
        font-weight: bold;
        z-index: 2;
        transition: all ease .5s;
    }
    header .logo .txt:hover span{
        color: #fff;
    }
    header .logo .txt .bg{
        position: absolute;
        top: 0px;
        left: 0px;
        width: 100%;
        height: 100%;
        background: #fff;
        transition: all ease .5s;
    }
    header .logo .txt:hover .bg{
        width: 0%;
    }
    header .logo .txt .bg::before,
    header .logo .txt .bg::after{
        content: '';
        position: absolute;
        width: 16px;
        height: 2px;
        background: #1d1e2c;
        top: 30px;
        left: 20px;
        transition: all ease .5s;
        z-index: 2;
    }
    header .logo .txt:hover .bg::before,
    header .logo .txt:hover .bg::after{
        background: #fff;
    }
    header .logo .txt .bg::after{
        transform: rotate(90deg);
    }

    header .menuBtn{
        right: 0px;
        z-index: 100;
        background: #1d1e2c;
    }
    header .menuBtn>*{
        z-index: 2;
    }
    header .menuBtn .t{
        font-size: 14px;
        line-height: 18px;
        font-weight: bold;
        color: #fff;
        position: absolute;
        right: 0px;
        top: calc(50% - 9px);
        transform: translateX(calc(50% - 29px)) rotate(90deg);
    }
    header .menuBtn .t span,
    header.clicked .menuBtn .t span:last-child{
        display: block;
    }
    header.clicked .menuBtn .t span,
    header .menuBtn .t span:last-child{
        display: none;
    }
    
    header .menuBtn .btn{
        margin-left: -10px;
    }
    header .menuBtn .btn span{
        display: block;
        margin: 0 auto;
        margin-top: 8px;
        width: 32px;
        height: 2px;
        background: #fff;
        transition: all ease .3s;
    }
    header .menuBtn .btn span:first-child{
        margin-top: 0px;
    }
    header.clicked .menuBtn .btn span:first-child,
    header.clicked .menuBtn .btn span:last-child{
        opacity: 0;
    }
    header .menuBtn .btn span:nth-child(2),
    header.clicked .menuBtn .btn span:nth-child(3){
        width: 40px;
    }
    header.clicked .menuBtn .btn span:nth-child(2){
        transform: translateY(5px) rotate(45deg);
    }
    header.clicked .menuBtn .btn span:nth-child(3){
        transform: translateY(-5px) rotate(-45deg);
    }
    header .menuBtn .bg{
        position: absolute;
        z-index: 0;
        width: 0%;
        height: 100%;
        top: 0px;
        right: 0px;
        background: #7C674A;
        transition: all ease .5s;
    }
    .mobileDevice header .menuBtn:hover .bg{
        width: 0%;
    }
    header .menuBtn:hover .bg{
        width: 100%;
    }
    header.clicked .menuBtn .bg{
        width: 100% !important;
    }



    header .menu{
        z-index: 95;
        position: fixed;
        width: 100%;
        height: 100vh;
        top: 0px;
        left: 0px;
        transition: ease .5s all;
        background: url(../../img/common/) center center no-repeat;
        background-size: cover;
        opacity: 0;
        pointer-events: none;
    }
    header .menu::before{
        content: '';
        width: 100%;
        height: 100%;
        top:0px;
        left: 0px;
        background: #1d1e2c;
        z-index: -1;
        position: absolute;
    }
    header.clicked .menu{
        opacity: 1;
        pointer-events: all;
    }
    header .menu>a{
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        top: 65px;
        transition: all ease .7s;
        opacity: 0;
        z-index: 2;
    }
    header.clicked .menu>a{
        top: 115px;
        opacity: 1;
        transition-delay: .5s;
    }
    header .menu ul{
        width: 100%;
        position: absolute;
        left: 0px;
        counter-reset: subsection;
        top: 50%;
        transform: translateY(-50%);
    }
    header .menu ul li,
    header .menu ul .ttl{
        width: 225px;
    }
    header .menu ul li .box{
        display: block;
        width: 0%;
        overflow: hidden;
        transition: all ease 1.5s;
    }
    header .menu ul li{
        position: relative;
        z-index: 2;
        color: #fff;
    }
    header .menu ul li:nth-last-child(2){
        display: none;
    }
    header .menu ul li::before{
        content: '';
        position: absolute;
        height: 100vh;
        width: 0%;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%);
        background: #7C674A;
        transition: all ease .3s;
    }
    header .menu ul li.hover::before{
        width: 100%;
    }
    header .menu ul li .box{
        width: 100%;
        opacity: 0;
    }
    header.clicked .menu ul li .box{
        opacity: 1;
    }
    header.clicked .menu ul li:nth-child(1) .box{
        transition-delay: .7s;
    }
    header.clicked .menu ul li:nth-child(2) .box{
        transition-delay: .8s;
    }
    header.clicked .menu ul li:nth-child(3) .box{
        transition-delay: .9s;
    }
    header.clicked .menu ul li:nth-child(4) .box{
        transition-delay: 1s;
    }
    header.clicked .menu ul li:nth-child(5) .box{
        transition-delay: 1.1s;
    }
    header.clicked .menu ul li.hover .box{
        overflow: initial;
    }
    header .menu ul li .ttl{
        cursor: pointer;
        display: block;
        padding-top: 25px;
        padding-left: 55px;
        position: relative;
        font-size: 21px;
        line-height: 1;
        min-height: 42px;
        box-sizing: content-box;
        transition: all ease .5s;
    }
    header .menu ul li .ttl.f{
        cursor: default;
    }
    header .menu ul li .ttl::before{
        counter-increment: subsection;
        content: "0" counter(subsection);
        position: absolute;
        font-size: 18px;
        color: #686978;
        top: 0px;
        left: 20px;
        transition: all ease .3s;
    }
    header .menu ul li.hover .ttl::before{
        color: #c9b59e;
    }
    header .menu ul li .ttl::after{
        content: '';
        position: absolute;
        width: 32px;
        height: 2px;
        background: #686978;
        top: 6px;
        left: 55px;
        transition: all ease .3s;
    }
    header .menu ul li.hover .ttl::after{
        background: #c9b59e;
    }
   
    header .menu ul li .box .sonMenu{
        width: 0%;
        height: 0px;
        overflow: hidden;
        transition: width ease .1s,height ease .5s .1s;
    }
    header .menu ul li.hover .box .sonMenu{
        width: 100%;
        transition: width ease .5s .4s,height .5s ease;
    }
    header .menu ul li .box .sonMenu a{
        display: block;
        width: 225px;
        font-size: 17px;
        line-height: 1;
        padding-top: 20px;
        color: #fff;
    }
    
    .switch{
        background: #f3f3f3;
        border: 25px solid #fff;
        border-bottom-width: 60px;
        height: 100%;
        width: 100%;
        position: absolute;
        top: 0px;
        left: 0px;
        transition: all ease .7s;
        transform: scale(.9);
        opacity: 0;
        z-index: 0;
    }
    .switch.active{
        transform: scale(1) !important;
        opacity: 1;
        z-index: 2;
    }
    /*
    .switch:first-child{
        transform: scale(1);
        opacity: 1;
    }
    */
    .switch.active + .switch{
        transform: scale(1);
    }
    .switch.away{
        z-index: 2;
        pointer-events: none;
    }
    .switch .contn{
        height: 100%;
        position: relative;
    }
    .switch.leave .contn{
        transform: scale(1.1);
        filter: blur(10px);
        opacity: 0;
        transition: all .5s ease;
    }
    .switch .contn>*{
        position: absolute;
    }
    .switch .b{
        font-weight: 700;
    }
    .switch .contn .txt{
        left: 50%;
        transform: translateX(-600px);
        top: 20%;
        color: #1d1e2c;
        z-index: 2;
    }
    .switch .contn .txt .ttl{
        position: relative;
        padding-left: 95px;
        line-height: 1;
        font-size: 14px;
        font-weight: bold;
        white-space: nowrap;
    }
    .switch:not(.projects) .contn .txt .ttl{
        max-width: 95px;
        transform: translateX(-50px);
        opacity: 0;
        overflow: hidden;
    }
    .active.switch .contn .txt .ttl{
        opacity: 1;
        transform: translateX(0px);
        transition: transform .5s 1.5s ease-in, 
                    opacity .3s 1.5s ease, 
                    max-width .5s 2s ease-in;
    }
    
    .switch .contn .txt .ttl::before{
        content: '';
        position: absolute;
        width: 75px;
        height: 5px;
        background: #1d1e2c;
        left: 0;
        top: calc(50% - 1px);
        transform: translateY(-50%);
    }
    .switch .contn .txt .tip{
        line-height: 64px;
        margin-top: 17px;
        margin-bottom: 25px;
        font-weight: 100;
        font-size: 50px;
        white-space: nowrap;
    }
    .switch:not(.projects) .contn .txt .tip{
        max-width: 0%;
        overflow: hidden;
    }
    .switch.active .contn .txt .tip{
        max-width: 100%;
        transition: all .5s 1.5s ease-out;
    }
    .switch .contn .txt a{
        font-size: 14px;
        line-height: 1;
        padding: 17px 0px;
        width: 225px;
        position: relative;
        border: 3px solid #1d1e2c;
        font-weight: 700;    
        display: block;    
        text-align: center;  
        opacity: 0;
        transform: translateY(-50px);
    }
    .switch .contn .txt a + a{
        margin-left: 15px;
    }
    .active.switch .contn .txt a{
        opacity: 1;
        transition: all .7s 2.5s ease-out;
        transform: translateY(0px);
    }
    .switch .contn .txt a::after{
        content: '';
        position: absolute;
        width: 0%;
        height: 100%;
        left: 0px;
        top: 0px;
        transition: all ease .3s;
        background: #1d1e2c;
        z-index: -1;
    }
    .switch .contn .txt a:hover::after{
        width: 100%;
    }
    .switch .contn .txt a span{
        transition: all ease .3s;
    }
    .switch .contn .txt a:hover span{
        color: #fff;
    }
    .switch .contn .pic .picBox{
        overflow: hidden;
        opacity: 0;
        height: 0px;
        width: 600px;
    }
    .active.switch .contn .pic .picBox{
        transition: height 2s 0.5s cubic-bezier(0.12, 0.335, 0.01, 0.985),
                    opacity 0.3s ease;
        opacity: 1;
    }
    .active.switch .contn .pic + .pic .picBox{
        transition: height 2s 1s cubic-bezier(0.12, 0.335, 0.01, 0.985),
                        opacity 0.3s ease;
    }
    .switch .contn .btn{
        width: 75px;
        line-height: 150px;
        position: absolute !important;
        top: 50%;
        transform: translateY(-50%);
        z-index: 2;
        background: #fff;
        text-align: center;
    }
    .switch .contn .btn:before{
        content: '';
        position: absolute;
        width: 0%;
        height: 100%;
        background: #897053;
        transition: .3s ease all;
        top: 0px;
        z-index: -1;
    }
    .switch .contn .btn:hover:before{
        width: 100%;
    }
    .switch .contn .btn span{
        width: 18px;
        display: inline-block;
        vertical-align: middle;
        text-align: center;
        font-size: 18px;
        line-height: 140%;
        color: #1d1e2c;
        transition: all ease .3s;
        word-break: break-all;
    }
    .switch .contn .btn:hover span{
        color: #fff;
    }
    .switch .contn .btn.prev{
        left: 150px;
    }
    .switch .contn .btn.next{
        right: 150px;
    }
    .switch .contn .btn.prev::before{
        left: 0px;
    }
    .switch .contn .btn.next::before{
        right: 0px;
    }

    .switch .loc{
        z-index: 2;
        left: 25px;
        bottom: 12px;
    }
    .switch .loc .atPresent{
        color: #fff;
    }
    .switch .loc ul li{
        transition: .5s ease all;
    }
    .switch .loc ul li:hover{
        width: 180px;
    }
    .switch .loc ul li i{
        background: rgba(255,255,255,.5);
    }
    .switch .loc ul li i::before,
    .switch .loc ul li .preview::before{
        content: '';
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0px;
        left: 0px;
        transform-origin: left;
        transform: scaleX(0);
        background: #fff;
        opacity: 1;
        z-index: 2;
    }
    .switch .loc ul li.active i::before,
    .switch .loc ul li.active .preview::before{
        animation: loading 5s linear;
    }
    @keyframes loading{
        from{
            transform: scaleX(0);
        }to{
            transform: scaleX(1);
        }
    }
    .switch .loc ul li .preview{
        position: absolute;
        bottom: calc(50% + 1px);
        left: 0px;
        width: 100%;
        height: 0px;
        overflow: hidden;
        transition: .5s ease all;
    }
    .switch .loc ul li .preview::before{
        background: #1d1e2c;    
        opacity: .8;
    }
    .switch .loc ul li:hover .preview{
        height: 100px;
    }

    footer + .btmLft{
        width: 50%;
        position: absolute;
        bottom: 0px;
        left: 0px;
        height: 100px;
        transition: all ease .5s; 
        opacity: 0;
        pointer-events: none;
        z-index: 50;
    }
    footer + .btmLft.appear{
        opacity: 1;
        pointer-events: all;
        transition-delay: .7s;
    }
    .sNext{
        position: absolute;
        left: 72px;
        bottom: 85px;
        transition: all ease .3s;
    }
    .sNext.hidden,
    .loc.hidden{
        opacity: 0;
        pointer-events: none;
    }
    .sNext::before{
        content: '';
        position: absolute;
        width: 48px;
        height: 48px;
        left: 50%;
        top: 0px;
        border: 2px solid #897053;
        border-radius: 50%;
        transform: translateX(-50%);
    } 
    .sNext .r{
        width: 48px;
        height: 48px;
        margin: 0px auto;
        flex-direction: column;
    }
    .sNext .r span{
        opacity: .5;
        width: 5px;
        height: 5px;
        border-radius: 50%;
        overflow: hidden;
        margin-bottom: 3px;
        background: #897053;
        animation: light 1.5s linear infinite;
    }
    .sNext .r span:last-child{
        margin-bottom: 0px;
        animation-delay: .75s;
    }
    .sNext .r span:nth-child(2){
        animation-delay: .375s;
    }
    @keyframes light{
        0%{opacity:0.5}
        25%{opacity:1}
        50%{opacity:0.5}
        100%{opacity:0.5}
    }
    .sNext .t{
        text-align: center;
        font-size: 14px;
        font-weight: bold;
        margin-top: 13px;
        color: #897053;
    }

    .loc{
        position: absolute;
        left: 32px;
        width: 100%;
        bottom: 14px;
        transition: all ease .3s;
    }
    .loc .atPresent{
        line-height: 25px;
        font-size: 16px;
        color: #acadbd;
        margin-right: 20px;
    }
    .loc ul li{
        display: inline-block;
        width: 50px;
        position: relative;
        margin-right: 15px;
        height: 25px;
        cursor: pointer;
    }
    .loc ul li i{
        display: inline-block;
        vertical-align: middle;
        width: 100%;
        height: 2px;
        background: #d5d6e4;
        position: relative;
    }
    .loc ul li i::before{
        content: '';
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0px;
        left: 0px;
        opacity: 0;
        background: #897053;
        transition: .5s ease all;
    }
    .loc ul li.clicked i::before{
        opacity: 1;
    }

    footer{
        position: absolute;
        bottom: 12px;
        right: 25px;
        z-index: 90;
        color: #fff;
        font-size: 16px;
    }
    footer p{
        display: inline-block;
    }
    footer p:last-child{
        margin-left: 25px;
    }